

# The Implementation of YUV422 Output for SRV

Marvin Liang, Brijesh Jadav and Subhajit Paul

#### **ABSTRACT**

From a design perspective, the display subsystem (DSS) in the Jacinto<sup>™</sup>/TDA family of devices only supports RGB or non-standard embedded sync YUV422 output. This technical limitation creates a big problem when the car OEM integrates the ADAS system to an infotainment system, especially when replacing the rear view camera with the surround view function. This application report introduces a solution that outputs discrete YUV422 for a SRV system based on both VISION SDK and PSDKLA.

Project collateral and source code discussed in this document can be downloaded from the following URL: <a href="http://www.ti.com/lit/zip/spracg3">http://www.ti.com/lit/zip/spracg3</a>.

|                 | Contents                                                |   |
|-----------------|---------------------------------------------------------|---|
| 1               | Requirement for Supporting YUV422 Output                | 2 |
| 2               | YUV422 Format and Output Timing                         |   |
| 3               | Discrete Sync YUV422 Output Concept                     |   |
| 4               | Migration From RGB888 to YUV422 Output for SRV Use Case |   |
| List of Figures |                                                         |   |
| 1               | Benefit for Supporting YUV422 Output in SRV System      |   |
| 2               | BT.656 Frame Timing                                     | 2 |
| 3               | One Line Active Video Format for BT.656                 | 2 |
| 4               | Discrete Sync Output Timing                             | 3 |
| 5               | Bit Exact Output YUV422 From VIDx Pipeline              | 4 |
| 6               | YUV422 Output Through TDM                               | 5 |
| 7               | YUV422 Output for SRV Use Case                          | 6 |
| 8               | YUV422 Output Chain for SRV                             | 7 |
| 9               | YUV422 Output Implementation for SRV in PSDKLA          | 8 |

#### **Trademarks**

Jacinto is a trademark of Texas Instruments.

All other trademarks are the property of their respective owners.



## 1 Requirement for Supporting YUV422 Output

As shown in Figure 1, currently most cars have RVC function integrated, it connected to the infotainment system through FPD LINK/LVDS, the video format for RVC camera is YUV422 and in most cases, it use 8 bit interface. Now more OEMs plan to upgrade the RVC to 360 surround view function, or the RVC remain for low end car, SRV remain for medium/high end car. Because most SRV products which based on TI Jacinto/TDA family devices are only designed for RGB output and TI FPD LINK product always is a serializer/deserializer pair for specific video format conversion, for example UB933/UB934 for YUV422, UB921/UB924 for RGB, the infotainment system have to integrate two different deserializers for support both RVC and SRV function.

If SRV can output YUV422 as RVC camera, infotainment system will only need one YUV422 deserializers to support both RVC and SRV function.

It takes simplicity for the infotainment system design and flexibility for system deploying, also the cost benefit.



Figure 1. Benefit for Supporting YUV422 Output in SRV System

# 2 YUV422 Format and Output Timing

According to the TRM for DSS, DSS support output below format:

- 1. Embedded sync output interface for YUV422 format
- 2. Supports BT656 and BT1120 standards
- 3. Supports YUV422 format with 8bit color component
- 4. Outputs 8bit YUV422 over 10bit interface with valid pixel values on D[9:2] data lines
- 5. Discrete sync output interface for various bit depth of RGB format (RGB888, RGB565, RGB444)

# 2.1 Emded Sync Output



Figure 2. BT.656 Frame Timing



Figure 3. One Line Active Video Format for BT.656

For embedded sync output video format, only need PCLK and data lines. The synchronization signals are already packed into the video content as shown in Figure 2 and Figure 3. The receive side does not need HSYNC and VSYNC, but the video can be decoded with the packed vertical blanking, start of active video (SAV), and end of active video (EAV).



But there is a limitation for TI Jacinto/TDA family devices, as below CAUTION part in TRM:

#### **CAUTION**

DISPC supports maximum 256 bytes of horizontal blanking when the LCD outputs are configured in BT modes (bitfield HSW of DISPC\_TIMING\_H1/2/3 registers is 8 bits wide). This is not compliant with BT.656 and BT.1120 standards, both of which require higher blanking periods. If more than 256 bytes of horizontal blanking are required by the application, then the RGB mode must be used for the LCD outputs.

The Blanking Video definition in ITU-R-BT.656 (as shown in Figure 3) is 280 byte for PAL, 268 byte for NTSC, so it is very difficult to find a BT.656 decoder that can support the nonstandard BT.565 signals (blanking video 256 byte) from TI Jacinto/TDA family devices.

## 2.2 Discrete Sync Output





Figure 4. Discrete Sync Output Timing

DSS output a discrete video in Jacinto/TDA family devices shown as Figure 4:

- 1. Supports HSYNC, VSYNC, DE signals
- 2. Outputs 8bit data over 8bit interface with valid pixel on D[7:0] data lines
- 3. Supports multi cycle output format (TDM), where each pixel can be sent out over multiple clock cycle

VSYNC: Vertical Synchronization signal, it toggles after all the lines in a frame are transmitted to the LCD panel and a programmable number of line clock cycles has elapsed at the beginning and end of each frame. There are three programmable variables to control VSYNC timing, VFP, VBP and VSW.

HSYNC: Horizontal synchronization Signal, it toggles after all pixels in a line are transmitted to the LCD panel and a programmable number of pixel clock has elapsed at the beginning and end of each line. There are three programmable variables to control VSYNC timing, HFP, HBP and HSW.



DE: Data Enable Signal, it acts as an output-enable signal to indicate when data must be latched using the pixel clock. DE timing depends on the HFP, HBP and HSW configuration

DSS adds one to the configured value for the field HFP, HBP and HSW, so for these fields, the minimum period is one clock cycle. If these fields are configured with value 0, DSS outputs single clock cycle for these fields.

All three sync signal can be inverted in the DSS.

Because of the limitation of BT.656, the implementation of this application note is targeted to discrete sync YUV422.

## 3 Discrete Sync YUV422 Output Concept

### 3.1 The Function Modules Bypass in VID Pipeline



Figure 5. Bit Exact Output YUV422 From VIDx Pipeline

Since our DSS CSC submodule cannot convert RGB to YUV, the basic concept to get YUV422 output is that input YUV422 format to a specific video pipeline and get bit exact output.

For providing the overlay feature, it requires the input video format as RGB, because only RGB can have alpha characteristic. So the video pipeline always converts the non-RGB input to RGB format internally. When input video is YUV422 format and configure the format to YUV422, video pipeline will convert it. For voiding this default hardware behavior, the hardware needs to be cheated to deal the YUV422 as RGB. Since both YUV422 and RGB565 are 16 bit data, cheat hardware deal YUV422 as RGB565 is possible.

Each of the processing blocks present in the video pipelines has a bypass path (see Figure 5), which can be selected to send the data unaltered by the video pipeline. Input data format of the video pipeline should be configured as RGB16-565. VC-1 range mapping and CSC blocks of the video pipelines will be bypassed by default for this format. Input and output width and height of the video pipeline should be configured to same values to bypass the scaling block. With the above configuration the data coming to video pipeline from DMA engine will reach the overlay unaltered.

#### Register Configuration:

```
DISPC_VID1_ATTRIBUTES.FORMAT = 0x6; RGB16-565

DISPC_VID1_ATTRIBUTES.RESIZEENABLE = 0x0; Disable both horizontal and vertical resize processing

DISPC_VID1_SIZE.SIZEX == DISPC_VID1_PICTURE_SIZE.MEMSIZEX

DISPC_VID1_SIZE.SIZEY == DISPC_VID1_PICTURE_SIZE.MEMSIZEY

DISPC_CONFIG1.TCKLCDENABLE = 0; Disable the transparency color key for the LCD

DISPC_CONFIG1.CPR = 0; Color Phase Rotation Disabled

}
```



## 3.2 TDM for Transferring YUV422

Since RGB565 and YUV422 are both 16 bit per pixel data, for transferring a pixel through 8-bit interface, it can be divide to dual 8 bit, each one can be transferred by one cycle. Figure 6 shows the TDM timing to output YUV22 pixel.



16bpp through 8 bit

1st cycle

Y[7]
Y[6]
Y[5]
Y[5]
Y[4]
Y[2]
Y[2]
Y[1]
Y[0]
V[1]
Y[1]
Y[0]

Figure 6. YUV422 Output Through TDM

#### Register Configuration:

```
DISPC_VP1_CONTROL.TDMENABLE = 0x1: TDM enabled
DISPC_VP1_CONTROL. TDMPARALLELMODE = 0x0: 8-bit parallel output interface selected
DISPC_VP1_CONTROL. TDMCYCLEFORMAT = 0x2: 2 cycles for 1 pixel
DISPC_DATA1_CYCLE1 = 0x8
DISPC_DATA1_CYCLE2 = 0x8
DISPC_DATA1_CYCLE3 = 0x0
```



## 4 Migration From RGB888 to YUV422 Output for SRV Use Case

Considering a typical SRV use case, Figure 7 provides a system level overview that how to migrate from RGB888 output to YUV422 output. This use case example is based on J6 Entry/DRA71x, which does not have the VOUT1 interface.



Figure 7. YUV422 Output for SRV Use Case

DSP algorithm output YUV422 frames for parking assistance lines bind to VID2 pipeline

GPU output stitched 3D SRV RGB888 frame bind to VID3 pipeline

A15/MiniGUI output the RGB888 UI frame bind to GFX pipeline

After the overlay for above three frames, it can output RGB888 through 24 bit interface directly. For outputting YUV422, it has to be routed to writeback pipeline and convert the RGB888 to YUV422 in the memory. Then an application should schedule the new YUV422 frame as input to VID1 pipeline. The VID1 pipeline has been already configured as YUV422 bit exact output that are described Section 3.1 and Section 3.2.

## 4.1 YUV422 output migration for SRV on VISIDONSDK

The YUV422 output migration for SRV from RGB888 output on VISIONSDK is not so complex. Most modifications are made for display control link, only need add one more stage, the writeback capture link. Figure 8 shows the VISIONSDK link for the SRV use case with YV422 output.





Figure 8. YUV422 Output Chain for SRV



# 4.2 YUV422 Output Migration for SRV on PSDKLA

When implement the YUV422 output in PSDKLA, it is more difficult than VISION SDK since Linux have the display driver framework as DRM. The modification cannot be made straight forward like VISIONSDK M4 display link/driver, it has to be followed the DRM methodology.



Figure 9. YUV422 Output Implementation for SRV in PSDKLA

Figure 9 shows the YUV422 output implementation for SRV with Linux DRM framework:

- 1. DSP algorithm output YUV422 frames for parking assistance lines bind to CRTC34-Plane40 (VID2 pipeline)
- 2. GPU output stitched 3D SRV RGB888 frame bind to CRTC34-Plane39(VID3 pipeline)
- A15/MinuGUI output the RGB888 UI frame bind to CRTC34-Plane33 (GFX pipeline)
   Note: The CRTC34 is a dummy CRTC which only have dummy encoder and connect, no actual video output to outside the DSS.
- 1. A Linux user mode program should take the buffer from the DSS writeback capture device (/dev/video11) by standard V4L2 driver, also configure the output format of /dev/video11 as YUV422.
- 2. The captured YUV422 frame can be bind to CRTC38-Plane37 (VID1 pipeline)

The corresponding encoder/connector for CRTC38 output the YUV422

## 4.3 Verification for YUV422 Output

As shown in Figure 9, the YUV422 output can be verified by two ways:

- Loopback the serializer of DSS output to the deserializer of J6 Entry's VIP. For this case, prefer to use DE signal instead of using HSYNC signal from DSS. VIP should capture the excellent YUV422 video without requiring the cropping of data.
- Connect the serializer of DSS output to the deserializer of a LCD which supported YUV422 input. For this case, prefer to use HSYNC signal directly from DSS, because most LCD are requiring the Hblanking timing (HFP/HSW/HBP).

8

#### IMPORTANT NOTICE FOR TI DESIGN INFORMATION AND RESOURCES

Texas Instruments Incorporated ("TI") technical, application or other design advice, services or information, including, but not limited to, reference designs and materials relating to evaluation modules, (collectively, "TI Resources") are intended to assist designers who are developing applications that incorporate TI products; by downloading, accessing or using any particular TI Resource in any way, you (individually or, if you are acting on behalf of a company, your company) agree to use it solely for this purpose and subject to the terms of this Notice.

TI's provision of TI Resources does not expand or otherwise alter TI's applicable published warranties or warranty disclaimers for TI products, and no additional obligations or liabilities arise from TI providing such TI Resources. TI reserves the right to make corrections, enhancements, improvements and other changes to its TI Resources.

You understand and agree that you remain responsible for using your independent analysis, evaluation and judgment in designing your applications and that you have full and exclusive responsibility to assure the safety of your applications and compliance of your applications (and of all TI products used in or for your applications) with all applicable regulations, laws and other applicable requirements. You represent that, with respect to your applications, you have all the necessary expertise to create and implement safeguards that (1) anticipate dangerous consequences of failures, (2) monitor failures and their consequences, and (3) lessen the likelihood of failures that might cause harm and take appropriate actions. You agree that prior to using or distributing any applications that include TI products, you will thoroughly test such applications and the functionality of such TI products as used in such applications. TI has not conducted any testing other than that specifically described in the published documentation for a particular TI Resource.

You are authorized to use, copy and modify any individual TI Resource only in connection with the development of applications that include the TI product(s) identified in such TI Resource. NO OTHER LICENSE, EXPRESS OR IMPLIED, BY ESTOPPEL OR OTHERWISE TO ANY OTHER TI INTELLECTUAL PROPERTY RIGHT, AND NO LICENSE TO ANY TECHNOLOGY OR INTELLECTUAL PROPERTY RIGHT OF TI OR ANY THIRD PARTY IS GRANTED HEREIN, including but not limited to any patent right, copyright, mask work right, or other intellectual property right relating to any combination, machine, or process in which TI products or services are used. Information regarding or referencing third-party products or services does not constitute a license to use such products or services, or a warranty or endorsement thereof. Use of TI Resources may require a license from a third party under the patents or other intellectual property of TI.

TI RESOURCES ARE PROVIDED "AS IS" AND WITH ALL FAULTS. TI DISCLAIMS ALL OTHER WARRANTIES OR REPRESENTATIONS, EXPRESS OR IMPLIED, REGARDING TI RESOURCES OR USE THEREOF, INCLUDING BUT NOT LIMITED TO ACCURACY OR COMPLETENESS, TITLE, ANY EPIDEMIC FAILURE WARRANTY AND ANY IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, AND NON-INFRINGEMENT OF ANY THIRD PARTY INTELLECTUAL PROPERTY RIGHTS.

TI SHALL NOT BE LIABLE FOR AND SHALL NOT DEFEND OR INDEMNIFY YOU AGAINST ANY CLAIM, INCLUDING BUT NOT LIMITED TO ANY INFRINGEMENT CLAIM THAT RELATES TO OR IS BASED ON ANY COMBINATION OF PRODUCTS EVEN IF DESCRIBED IN TI RESOURCES OR OTHERWISE. IN NO EVENT SHALL TI BE LIABLE FOR ANY ACTUAL, DIRECT, SPECIAL, COLLATERAL, INDIRECT, PUNITIVE, INCIDENTAL, CONSEQUENTIAL OR EXEMPLARY DAMAGES IN CONNECTION WITH OR ARISING OUT OF TI RESOURCES OR USE THEREOF, AND REGARDLESS OF WHETHER TI HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.

You agree to fully indemnify TI and its representatives against any damages, costs, losses, and/or liabilities arising out of your non-compliance with the terms and provisions of this Notice.

This Notice applies to TI Resources. Additional terms apply to the use and purchase of certain types of materials, TI products and services. These include; without limitation, TI's standard terms for semiconductor products <a href="http://www.ti.com/sc/docs/stdterms.htm">http://www.ti.com/sc/docs/stdterms.htm</a>), evaluation modules, and samples (<a href="http://www.ti.com/sc/docs/sampterms.htm">http://www.ti.com/sc/docs/sampterms.htm</a>).

Mailing Address: Texas Instruments, Post Office Box 655303, Dallas, Texas 75265 Copyright © 2018, Texas Instruments Incorporated